#### Chapter 3

#### Mano's Basic Computer

#### **REVIEW**

- We introduced registers
- We discussed the kinds of Transfer, Arithmetic, Logic and Shift Microoperations
- We discussed general aspects of CPU, Memory and Bus architectures
- In this chapter we introduce a more complicated <u>basic computer and show how its</u> <u>operation can be specified with register</u> <u>transfer statements</u>

#### CONSIDERING THE NEXT PROBLEM IN DESIGN

# A computer organization involves combining everything we have learned to date into a single integrated unit

What is a computer?

# Von Neuman refers to a computer as a "stored program digital computer"

- What is a program?
  - What is an instruction?

How are instructions executed?

#### **GOALS**

# We conclude our lecture series by considering computer organization

Combining the CPU, Memory and Bus architectures

#### We introduce the concept of an instruction

- Instruction design and architecture
- Microoperation sequencing (timing, control)
- Roles of different registers

We will follow a model of a virtual/logical computer organization adapted from M. Mano (Computer System Architecture, 3d Edition)

#### **COMPUTER - HIGH LEVEL VIEW**

CPU, Memory and Bus architectures with interface to I/O.



#### MANO'S COMPUTER SPECIFICATION

- Mano has a Memory (RAM) of 4096 words.
- This requires an Address bus of 12 bits.
- \* Each word is 16 bits long.
- The Data bus carries exactly 1 word of data between Memory and CPU.
- It has 8 registers.
- Input and Output is defined using the ASCII code of length 8 bits.





- Instruction is stored in one 16-bit memory word,
- ❖ It consists 4 bits for the operation code (abbreviated opcode) to specify one out of 16 possible operations, and 12 bits to specify the address of an operand (data used).
- ❖ The control reads a 16-bit instruction from the program portion of memory. It then executes the operation specified by the operation code.
- Computers that have a single-processor register usually assign to it the name Accumulator and label it AC.

#### FETCH - DECODE - EXECUTE CYCLE



#### THE MANO MODEL OF THE CPU REGISTERS

### CPU registers used in the model (Mano), categorized by length:

```
PC :: Program counter (hold address of next inst. – 12 bits)
■AR :: Address register (holds address for memory– 12 bits)
```

- DR :: Data register (holds memory operand— 16 bits)
- AC :: Accumulator (processor register holds data 16 bits)
- IR :: Instruction register (holds instruction code 16 bits)
- TR :: Temporary register (holds temporary data 16 bits)
- ■INR :: Input buffer register (holds input ASCII data 8 bits)
- OUTR :: Output buffer register (holds output ASCII data 8 bits)

```
SCR: Sequence counter register (4 bits)
```

E, R :: Single bit flip-flops (flag/utility, interrupt)

#### **BASIC COMPUTER REGISTERS AND MEMORY**





#### STORED PROGRAMS

A stored program is a set of instructions and data expressed in binary language, stored in non-volatile (ie. disk storage) memory

#### Programs can be executed only from Memory.

- Thus, a program must be loaded from disk to RAM in order to execute it.
- Loaded programs are called processes.
- Individual instructions must be transferred to the CPU where they are executed, using data that must be obtained from either CPU registers or RAM
- A process is executed by executing each individual instruction that, collectively, fulfill the intentions of the programmer.

#### COMPUTER INSTRUCTION

- A computer instruction is a <u>binary code</u> that specifies a sequence of microoperations for the computer.
- Instruction codes together with data are stored in memory (RAM).
- The computer reads each instruction from memory and places it in a <u>control register</u>.
- The control then <u>interprets</u> the binary code of the instruction and proceeds to execute it by issuing a <u>sequence of microoperations</u>.
- Operations such as: add, subtract, multiply, shift, and complement.
- The number of bits required for the operation code of an instruction depends on the total number of operations available in the computer.

### RELATIONSHIP BETWEEN A COMPUTER OPERATION AND A MICROOPERATION

- An operation is <u>part of an instruction stored in</u> <u>computer memory</u>. It is a binary code that tells the computer to perform a specific operation.
- For every operation code, the control issues a sequence of microoperations needed for the hardware implementation of the specified operation.
- An instruction code must specify not only the operation but also the registers (by binary code) or the memory words (by address) where the operands are to be found, as well as the register or memory word where the result is to be stored.

#### INSTRUCTION ARCHITECTURE

The list of all instructions engineered for a computer's CPU is called the *instruction* set.

To distinguish each instruction, they are assigned a <u>unique</u> numeric code

- Can be done in many ways
- Does not need to be ordinal (ie. starting from 0 and running contiguously)
- Can be partially ordinal and partially hierarchical
  - Mano's approach

Instructions must be capable of referencing Memory and/or CPU addresses in order to cause data to be transferred and operated on.

#### **INSTRUCTION FORMAT**

#### Instructions usually consist of:

- Operation code (opcode) part
- Address part

0

- Addressing Mode part
  - Direct addressing data found at the specified address
  - Indirect addressing data found at the address found at the specified address (pointer consent)

The number of memory referenced operands varies from computer to computer.

Mano simplifies the instruction architecture to permit <u>zero</u> or <u>one</u> memory address field. In the case of Indirect addressing mode there are two memory accesses, but only one reference.

Mode bit I OpCode Address

#### MANO'S INSTRUCTION FORMAT

- In Mano's Computer, since the memory contains 4096 (= 2<sup>12</sup>) words, we needs 12 bit to specify which memory address this instruction will use
- Bit 15 of the instruction specifies the addressing mode (0: direct addressing, 1: indirect addressing)
- 3 bits for the instruction's opcode (possible 8 operations)

#### MANO'S COMPUTER INSTRUCTION FORMAT



#### (b)Register -reference instruction



#### **INSTRUCTION HIERARCHY**

Mano's instruction set consists of 25 instructions:

| Instruction                       |                                 |                                                |                                                                                     |                                                                                     |  |  |  |
|-----------------------------------|---------------------------------|------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--|--|--|
| OpCode (000-110)                  |                                 |                                                | OpCode (111)                                                                        |                                                                                     |  |  |  |
| Di                                | rect (I=0)                      | Indirect (I=1)                                 | Direct (I=0)                                                                        | Indirect (I=1)                                                                      |  |  |  |
| 4 b<br>0<br>1<br>2<br>3<br>4<br>5 | it code AND ADD LDA STA BUN BSA | 4 bit code 8 AND 9 ADD A LDA B STA C BUN D BSA | 16 bit code<br>7800 CLA<br>7400 CLE<br>7200 CMA<br>7100 CME<br>7080 CIR<br>7040 CIL | 16 bit code<br>F800 INP<br>F400 OUT<br>F200 SKI<br>F100 SKO<br>F080 ION<br>F040 IOF |  |  |  |
| 6                                 | ISZ 7                           | E ISZ                                          | 7020 INC 7010 SPA 7008 SNA 7004 SZA 7002 SZE 7001 HLT                               | <b>6</b>                                                                            |  |  |  |

| / = 0 | Code                                                                                                                                   | 4                                                             |
|-------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
|       | <i>  = 1</i>                                                                                                                           | Description                                                   |
| 0xxx  | 8xxx                                                                                                                                   | AND memory word to AC                                         |
| 1xxx  | 9xxx                                                                                                                                   | Add memory word to AC                                         |
| 2xxx  | Axxx                                                                                                                                   | Load AC from memory                                           |
| 3xxx  | Bxxx                                                                                                                                   | Store content of AC into memory                               |
| 4xxx  | Cxxx                                                                                                                                   | Branch unconditionally                                        |
| 5xxx  | Dxxx                                                                                                                                   | Branch and save return address                                |
| 6xxx  | Exxx                                                                                                                                   | Increment and skip if zero                                    |
| 78    | 00                                                                                                                                     | Clear AC                                                      |
|       |                                                                                                                                        | Clear E                                                       |
|       |                                                                                                                                        | Complement AC                                                 |
|       |                                                                                                                                        | Complement E                                                  |
|       |                                                                                                                                        | Circulate right AC and E                                      |
|       |                                                                                                                                        | Circulate left AC and E                                       |
|       |                                                                                                                                        | Increment AC                                                  |
|       |                                                                                                                                        | Skip next instr. if AC is positive                            |
|       |                                                                                                                                        | Skip next instr. if AC is negative                            |
|       |                                                                                                                                        | Skip next instr. if AC is zero                                |
|       |                                                                                                                                        | Skip next instr. if E is zero                                 |
|       |                                                                                                                                        | Halt computer                                                 |
| Eo    | 00                                                                                                                                     | Input character to AC                                         |
|       |                                                                                                                                        | Input character to AC                                         |
|       |                                                                                                                                        | Output character from AC                                      |
|       |                                                                                                                                        | Skip on input flag                                            |
|       |                                                                                                                                        | Skip on output flag                                           |
|       |                                                                                                                                        | Interrupt on Interrupt off                                    |
|       | 1xxx<br>2xxx<br>3xxx<br>4xxx<br>5xxx<br>6xxx<br>78<br>74<br>72<br>71<br>70<br>70<br>70<br>70<br>70<br>70<br>70<br>70<br>70<br>70<br>70 | 1xxx 9xxx<br>2xxx Axxx<br>3xxx Bxxx<br>4xxx Cxxx<br>5xxx Dxxx |

#### INSTRUCTION SET COMPLETENESS

# Selection of instructions should span a variety of applications suitable to support programming

- Arithmetic, logical and shift instructions
- Instructions for moving data to and from memory and CPU registers
- Program control instructions, instructions that check status conditions

**Input and Output instructions** 

#### INSTRUCTION SET COMPLETENESS

Set of instructions using which user can construct machine language programs to evaluate any computable function.

Instruction Types

**Functional Instructions** 

- Arithmetic, logic, and shift instructions
- ADD, CMA, INC, CIR, CIL, AND, CLA (other than ADD/AND?)

**Transfer Instructions** 

- Data transfers between the main memory and the processor registers
- LDA, STA

**Control Instructions** 

- Program sequencing and control
- BUN, BSA, ISZ

**Input/Output Instructions** 

- Input and output
- INP, OUT

#### INSTRUCTION CYCLE

- In Computer, a machine instruction is executed in the following cycle:
  - 1. Fetch an instruction from memory
  - 2. Decode the instruction and calculate effective address (EA)
  - 3. Read the EA from memory if the instruction has an indirect address (Fetch operand)
  - 4. Execute the instruction
- Upon the completion of step 4, the control goes back to step 1 to fetch, decode, and execute the next instruction.
- This process continues indefinitely unless a <u>HALT</u> instruction is encountered.

#### FETCH AND DECODE CYCLE

Microoperations for the fetch and decode phases can be specified by the following register transfer statements:

```
T<sub>0:</sub> AR \leftarrow PC Fetch from memory the current instruction (which address is in PC)

T<sub>1:</sub> IR \leftarrow M[AR]; PC \leftarrow PC+1

T<sub>3</sub>: D<sub>0</sub>,...,D<sub>7</sub> Decode IR(12-14),AR \leftarrow IR(0-11), I \leftarrow IR(15)
```

Decode instruction found now in IR

#### DETERMINE THE TYPE OF INSTRUCTION

- ☐ We use bits 12, 13, 14 as input to the decoder to determine the type of instruction
- ☐ Only one of the decoder outputs = 1 at certain combination (i.e. operation) of the inputs.



#### DETERMINE THE TYPE OF INSTRUCTION



 $D'_7IT_3$ : AR  $\leftarrow$  M[AR]

D'7l'T3: Nothing

D7l'T3: Execute a register-reference instr.

D7IT3: Execute an input-output instr.

### DIFFERENCE BETWEEN DIRECT AND INDIRECT ADDRESSING



#### 1. MEMORY-REFERENCE INSTRUCTIONS:

| Symbol                       | Operation<br>Decoder | Symbolic description                             |
|------------------------------|----------------------|--------------------------------------------------|
| AND                          | $D_0$                | AC← AC ^M[AR]                                    |
| ADD                          | $D_1$                | $AC \leftarrow AC + M[AR], E \leftarrow C_{OUT}$ |
| LDA (load to accumulator)    | $D_2$                | AC← M[AR]                                        |
| STA (Store from accumulator) | $D_3$                | M[AR] ← AC                                       |
| BUN (branch unconsitionally) | D <sub>4</sub>       | PC ← AR                                          |
| BSA                          | $D_5$                | M[AR] ← PC, PC←AR+1                              |
| ISZ                          | D <sub>6</sub>       | $M[AR] \leftarrow M[AR]+1$ ,                     |

#### DO: AND: AND TO AC

- □ This is an instruction that performs the <u>AND logic</u> <u>operation</u> on pairs of bits in <u>AC</u> and the <u>memory</u> <u>word</u> specified by the effective address found in (AR) now.
- We can not work on the memory location directly, we have to bring the data to DR (Data Register) first.
- $\Box$  The result of the operation is transferred to AC.
- ☐ The microoperations that execute this instruction are:

$$D_0T_4$$
: DR  $\leftarrow$  M[AR]

$$D_0T_5$$
: AC $\leftarrow$  AC ^DR, SC $\leftarrow$  0

#### D1: ADD: ADD TO AC

- □ This instruction adds the content of the memory word specified by the effective address found in (AR) now to the value of AC.
- We can not work on the memory location directly, we have to bring the data to DR (Data Register) first.
- $\Box$  The result of the operation is transferred to AC.
- ☐ The microoperations that execute this instruction are:

$$D_1T_4$$
:  $DR \leftarrow M[AR]$ 

$$D_1T_5$$
: AC $\leftarrow$  AC +DR, E $\leftarrow$ Cout, SC $\leftarrow$  0

#### D2: LDA: LOAD TO AC

- ☐ This instruction transfers the memory word specified by the effective address found in (AR) now to AC.
- We can not work on the memory location directly, we have to bring the data to DR (Data Register) first.
- ☐ The microoperations that execute this instruction are:

 $D_2T_4$ :  $DR \leftarrow M[AR]$ 

$$D_2T_5$$
: AC $\leftarrow$  DR, SC $\leftarrow$  0

#### D3: STA: STORE AC

- □ This instruction stores the content of AC into the memory word specified by the effective address found in (AR) now.
- ☐ The microoperation that execute this instruction is:

 $D_3T_4$ : M[AR]  $\leftarrow$  AC, SC $\leftarrow$  0

#### **D4: BUN: BRANCH UNCONDITIONALLY**

- □ This instruction transfers the program to the instruction specified by the effective address found in (AR) now.
- □ The BUN instruction allows the programmer to specify an instruction out of sequence and we say that the program branches (or jumps) unconditionally.
- ☐ The effective address from AR is transferred through the common bus to PC.
- ☐ The microoperation that execute this instruction is:

 $D_4T_4$ :  $PC \leftarrow AR$ ,  $SC \leftarrow 0$ 

#### **D5: BSA: BRANCH AND SAVE RETURN ADDRESS**

- ☐ This instruction is useful for branching to a portion of the program called a subroutine or procedure.
- □ When executed, the BSA instruction stores the address of the next instruction in sequence (which is available in PC) into a memory location specified by the effective address found in (AR) now.
- □ The effective address plus one is then transferred to PC to serve as the address of the first instruction in the subroutine.
- ☐ The microoperation that execute this instruction is:

$$D_4T_4$$
: M[AR]  $\leftarrow$  PC, AR  $\leftarrow$  AR + 1,  $D_5T_4$ : PC  $\leftarrow$  AR, SC  $\leftarrow$  0

#### **EXAMPLE ON BSA**

- □ The BSA instruction is assumed to be in memory at address 20
- ☐ The *I bit* is 0 and the address part of the instruction has the binary equivalent of 135.
- ☐ After the fetch and decode phases, PC contains 21, which is the address of the next instruction in the program (referred to as the <u>return address</u>).
- ☐ AR holds the effective address 135.
- The BSA instruction performs the following numerical operation:

 $M[135] \leftarrow 21, PC \leftarrow 135 + 1 = 136$ 



Figure 3.8 Example of BSA instruction execution.

### **D6: ISZ: INCREMENT AND SKIP IF ZERO**

- This instruction increments the word specified by the effective address found in (AR) now, and if the incremented value is equal to 0, PC is incremented by 1.
   The programmer usually stores a negative number (in 2's complement) in the memory word (AR).
   As this negative number is repeatedly incremented by one, it eventually reaches the value of zero.
   At that time PC is incremented by one in order to skip the next instruction in the program.
- □ Since it is not possible to increment a word inside the memory, it is necessary to read the word into DR, increment DR, and store the word back into memory.

### ☐ The microoperations that execute this instruction are:

$$D_6T_4$$
:  $DR \leftarrow M[AR]$ 

$$D_6T_5$$
:  $DR \leftarrow DR + 1$ 

$$D_6T_6$$
:  $M[AR] \leftarrow DR$ ,  $if(DR=0)$  then  $(PC \leftarrow PC + 1)$ ,  $SC \leftarrow 0$ 



# REGISTER REFERENCE INSTRUCTIONS 12 INSTRUCTIONS, STARTS WITH 0111

| Hex  | Mnemonic | Binary coding                   | Meaning                      |
|------|----------|---------------------------------|------------------------------|
| 7800 | CLA      | <b>01111</b> 00000000000        | CLear Accumulator            |
| 7400 | CLE      | 0111010000000000                | CLear E                      |
| 7200 | CMA      | <b>0111001</b> 000000000        | CoMplement Accumulator       |
| 7100 | CME      | 0111000 <mark>1</mark> 00000000 | CoMplement E                 |
| 7080 | CIR      | 0111000010000000                | CIrcular shift Right         |
| 7040 | CIL      | 011100000 <mark>1</mark> 000000 | CIrcular shift Left          |
|      |          |                                 |                              |
| 7020 | INC      | 0111000000100000                | INCrement AC                 |
|      |          |                                 |                              |
| 7010 | SPA      | 0111000000010000                | Skip if Positive Accumulator |
| 7008 | SNA      | 011100000000 <mark>1</mark> 000 | Skip if Negative Accumulator |
| 7004 | SZA      | <b>0111000000000100</b>         | Skip if Zero Accumulator     |
| 7002 | SZE      | 0111000000000010                | Skip if Zero E               |
|      |          |                                 |                              |
| 7001 | HLT      | 0111000000000001                | HaLT the computer            |
| 7001 | HLT      | 0111000000000001                | HaLT the computer            |

□ Within this instruction subset, we group the instructions by which register is affected

| <u>Hex</u> | Mnemonic |                  |
|------------|----------|------------------|
| 7800       | CLA      |                  |
| 7200       | CMA      |                  |
| 7080       | CIR      | AC affected      |
| 7040       | CIL      | 8 instructions   |
| 7020       | INC      |                  |
| 7010       | SPA      |                  |
| 7008       | SNA      |                  |
| 7004       | SZA      |                  |
|            |          |                  |
| 7400       | CLE      | E affected       |
| 7100       | CME      | 3 instructions   |
| 7002       | SZE      |                  |
|            |          |                  |
| 7001       | HLT      | Control affected |
|            |          |                  |

Clear, Complement or Increment: AC register.

|      |          |                     | CHA |
|------|----------|---------------------|-----|
| Hex  | Mnemonic | RTL                 | CMA |
| 7800 | CLA      | $\overline{AC} = 0$ | INC |
| 7200 | CMA      | $AC = \sim AC$      | AC  |
| 7020 | INC      | AC = AC + 1         |     |

CT A

Clear, Complement: E register

|      |          |              | CLE |
|------|----------|--------------|-----|
| Hex  | Mnemonic | RTL          | CME |
| 7400 | CLE      | E = 0        | E   |
| 7100 | CME      | $E = \sim E$ |     |

### Shift AC register.

- This is a <u>circular</u> shift that is performed using the **E** register
- Control over timing ensures all operations operate in parallel
  - Eg. Use master-slave flip-flops in registers

| Hex  | Mnemonic | RTL                               |
|------|----------|-----------------------------------|
| 7080 | CIR      | $\overline{AC(0-14)} = AC(1-15),$ |
|      |          | AC(15) = E, E = AC(0)             |
| 7040 | CIL      | AC(1-15) = AC(0-14),              |
|      |          | AC(0) = E, E = AC(15)             |



#### Skip on <condition>: AC register.

- Tests sign/value status of 2's complement integer in AC
- If status matches query, advance PC by one instruction word

| <u>Hex</u> | Mnemonic | RTL                                 |
|------------|----------|-------------------------------------|
| 7010       | SPA      | $\overline{(AC > 0)} : PC = PC + 1$ |
| 7008       | SNA      | (AC < 0) : PC = PC + 1              |
| 7004       | SZA      | (AC = 0) : PC = PC + 1              |

### Skip on Zero condition: E register

- Test status of E bit. If <u>not zero</u>, proceed to the next instruction.
- If zero, advance PC by one instruction word (recall that it has already been incremented by one, so this causes skipping the next instruction in contiguous sequence.

```
Hex Mnemonic RTL
7002 SZE ~ E : PC = PC + 1
```

### Halting the computer

 Disable all circuits (over-ride all specific Enable controls with a general Disable).

| <u>Hex</u> | Mnemonic | <u>RTL</u> |     |          |
|------------|----------|------------|-----|----------|
| 7001       | HLT      | Disable    | all | circuits |

### We have $\underline{D_7 I/T_3} = r$ (common to all register-reference instructions) We have only one bit $IR(i) = B_i$ [bit in IR(0-11) that specifies

operation]

| r: <i>sc← 0</i>                                                                      | Clear <i>SC</i>        |
|--------------------------------------------------------------------------------------|------------------------|
| CLA <i>rB</i> <sub>11</sub> : AC← 0                                                  | Clear <i>AC</i>        |
| CLE $rB_{10}$ : $E \leftarrow 0$                                                     | Clear E                |
| CMA rB <sub>9</sub> : AC 	C                                                          | Complement AC          |
| CME <i>rB<sub>8</sub>: E← E</i>                                                      | Complement <i>E</i>    |
| CIR $rB_7$ : $AC \leftarrow$ shr $AC$ , $AC(15) \leftarrow E$ , $E \leftarrow AC(0)$ | Circulate right        |
| CIL $rB_6$ : AC $\leftarrow$ shi $AC$ , $AC(0) \leftarrow E$ , $E \leftarrow AC(15)$ | Circulate left         |
|                                                                                      |                        |
| INC <i>rB<sub>5</sub>: AC← AC</i> + 1                                                | Increment <i>AC</i>    |
| <b>SPA</b> $rB_4$ : If (AC(15) = 0) then (PC $\leftarrow$ PC+1)                      | Skip if positive       |
| SNA $rB_3$ : If $(AC(15) = 1)$ then $(PC \leftarrow PC + 1)$                         | Skip if negative       |
| SZA $rB_2$ : If $(AC = 0)$ then $(PC \leftarrow PC + 1)$                             | Skip if <i>AC</i> zero |
| SZE $rB_1$ : If(E = 0) then (PC $\leftarrow$ PC + 1)                                 | Skip if E zero         |
| HLT <i>rB<sub>s</sub>: S←</i> 0 <i>(S</i> is a start—stop flip-flop)                 | Halt computer          |

### INPUT, OUTPUT AND INTERRUPT INSTRUCTIONS



The input register *INPR* consists of eight bits and holds alphanumeric input information.

The 1-bit input flag FGI is a control flip-flop. The flag bit is set to 1 when new information is available in the input device and is cleared to 0 when the information accepted by the computer. The flag is needed to synchronize the timing rate difference between the input device and the computer.

### INPUT/OUTPUT INSTRUCTIONS

Each peripheral device has a communications and control interface that interacts with the computer's interface logic circuits

- Input
  - Need a data buffer (INPR) and a flag (FGI) indicating buffer empty/full
- Output
  - Need a data buffer (OUTR) and a flag (FGO) indicating buffer empty/full



## THE PROCESS OF <u>INPUT</u> INFORMATION TRANSFER IS AS FOLLOWS:

- 1. Initially, the input flag *FGI* is cleared to 0.
- 2. When a key is struck in the keyboard, an 8-bit alphanumeric code is shifted into *INPR* and the input flag *FGI* is set to 1. As long as the flag is set, the information in *INPR* cannot be changed by striking another key.
- 3. The computer checks the flag bit; if it is 1, the information from *INPR* is transferred in parallel into the eight low-order bits of *AC* and *FGI* is cleared to 0.
- 4. Once the flag is cleared, new information can be shifted into *INPR* by striking another key.

The output register *OUTR* works similarly but the direction of information flow is reversed.

## THE PROCESS OF OUTPUT INFORMATION TRANSFER IS AS FOLLOWS:

- 1. Initially, the output flag *FGO* is set to 1.
- 2. The computer checks the flag bit; if it is 1, the information in the eight least significant bits from AC is transferred in parallel to OUTR and FGO is cleared to 0.
- 3. The output device accepts the coded information, prints the corresponding character, and when the operation is completed, it sets *FGO* to 1.

The computer does not load a new character into **QUTR** when **FGQ** is 0 because this condition indicates that the output device is in the process of printing the character.

### INPUT/OUTPUT INSTRUCTIONS

### Used for communicating data between CPU and I/O peripheral devices

### Also, need instructions to support programmed polling.

Polling refers to <u>waiting for a condition</u> to be true before proceeding

```
OpCode Mnemonic Meaning
F800 INP Input ASCII char
F400 OUT Output ASCII char
F200 SKI Skip if input flag (FGI=1)
F100 SKO Skip if output flag (FGO=1)
```



## INPUT-OUTPUT INSTRUCTIONS INSTRUCTIONS STARTS WITH 0111

 $D_7/T_3 = p$  (common to all input—output instructions)  $IR(i) = B_i$  [bit in IR(6-11) that specifies the instruction]

p: *SC← 0* 

INP  $pB_{11}$ :  $AC(0-7) \leftarrow INPR, FGI \leftarrow 0$ 

OUT  $PB_{10}$ :  $OUTR \leftarrow AC(0-7)$ ,  $FGO \leftarrow 0$ 

SKI  $PB_9$ : If(FGI=1)then(PC $\leftarrow$ PC+1)

SKO  $PB_8$ : If(FGO=1)then(PC $\leftarrow$ PC+1)

Clear SC

Input character

Output character

Skip on input flag

**Skip on Output flag** 

ION PB7: IEN ←1

**IOF**  $PB_7: IEN \leftarrow 0$ 

Interrupt enable on

**Interrupt enable off** 

### **INTERRUPTS**

Input and Output interactions with electromechanical peripheral devices require huge processing times compared with CPU processing times

I/O (milliseconds) versus CPU (nano/micro-seconds)

Interrupts permit other CPU instructions to execute while waiting for I/O to complete

Need an <u>additional</u> 1-bit **IEN** flip-flop to store the interrupt status (0/1)

```
OpCode Mnemonic Meaning
F080 ION Interrupt Enabled (IEN ← 1)
F040 IOF Interrupt Disabled (IEN ← 0)

IR 1 1 1 1 I/O operation control bits
```

### INPUT- OUTPUT AND PROGRAM INTERRUPT



### **INTERRUPTS**

### In this approach, interrupts are used only with I/O handling

- In addition to a flip-flop to store the Interrupt Enable state, one more flip-flop (R) is needed to store the I/O Status (Ready/Not\_ready).
- In general, interrupts may be used with arbitrary instructions for exception trapping and handling



### INTERRUPT HANDLING FLOWCHART



### INTERRUPT HANDLING FLOWCHART



### **MULTIPLE INTERRUPTS**

### Multiple Interrupts - Sequential

# Interrupt User Program Handler X Interrupt Handler Y

### Multiple Interrupts – Nested



```
Feich
                           R'T_o: AR \leftarrow PC
                           R'T_1: IR \leftarrow M[AR], PC \leftarrow PC + 1
Decode
                           R'T_2: D_0,...,D_7 \leftarrow Decode\ IR(12-14),
                                     AR \leftarrow IR(0-11), I \leftarrow IR(15)
Indirect
                           D_{7}^{\prime}IT_{3}: AR \leftarrow M[AR]
Interrupt
  T_{\circ}T_{\circ}T_{\circ}'(IEN)(FGI+FGO):
                                      R \leftarrow 1
                             RT_o: AR \leftarrow 0, TR \leftarrow PC
                             RT_1: M[AR] \leftarrow TR, PC \leftarrow 0
                             RT_{+}: PC \leftarrow PC + 1, IEN \leftarrow 0, R \leftarrow 0, SC \leftarrow 0
Memory reference
 AND
                            D_0T_A:DR \leftarrow M[AR]
                            D_0T_s:AC \leftarrow AC \land AR, SC \leftarrow 0
 ADD
                            D.T_*:DR \leftarrow M[AR]
                            D_1T_s:AC \leftarrow AC + AR, E \leftarrow C_{OUT}, SC \leftarrow 0
 LDA
                            D_2T_4:DR \leftarrow M[AR]
                            D_3T_5:AC \leftarrow DR, SC \leftarrow 0
 STA
                            D_3T_4:M[AR] \leftarrow AC, SC \leftarrow 0
 BUN
                            D_4T_4:PC \leftarrow AR, SC \leftarrow 0
 BSA
                            D_sT_A:M[AR] \leftarrow PC, AR \leftarrow AR + 1
                            D_sT_s:PC \leftarrow AR, SC \leftarrow 0
 ISZ
                            D_oT_A:DR \leftarrow M[AR]
                            D_sT_s:DR \leftarrow DR + 1
                            D_6T_6:M[AR] \leftarrow DR, if (DR = 0)then(PC \leftarrow PC + 1), SC \leftarrow 0
Register-reference
                            D_{\gamma}IT_{\gamma} = r (common to all register reference instruction)
                            IR(i) = B_i (i = 0, 1, 2, ..., 11)
                                r: SC \leftarrow 0
                             rB .. :
                                       AC \leftarrow 0
 CLA
                             rB_{10}: E \leftarrow 0
 CLE
                             rB_o: AC \leftarrow \overline{AC}
 CMA
                             rB_s: E \leftarrow \overline{E}
 CME
                             rB_7: AC \leftarrow shrAC, AC(15) \leftarrow E, E \leftarrow AC(0)
 CIR
                             rB_s: AC \leftarrow shIAC, AC(0) \leftarrow E, E \leftarrow AC(15)
 CIL
                             rB_s: AC \leftarrow AC + 1
 INC
                             rB_A: If (AC(15) = 0)then(PC \leftarrow PC + 1)
 SPA
                             rB_3: If (AC(15) = 1)then(PC \leftarrow PC + 1)
 SNA
                             rB_{-}:
                                      If (AC = 0)then(PC \leftarrow PC + 1)
 SZA
 SZE
                             rB,:
                                      If (E = 0)then (PC \leftarrow PC + 1)
                             rBo:
                                      S \leftarrow 0
 HLT
Input -output
                            D_2IT_3 = p (common to all register reference instruction)
                            IR(i) = B_i (i = 6, 7, 8, 9, 10, 11)
                                P: SC \leftarrow 0
                            pB_{11}: AC(0-7) \leftarrow INPR, FGI \leftarrow 0
 INP
                            pB_{10}: OUTR \leftarrow AC(0-7), FGO \leftarrow 0
 OUT
                            pB_o: If (FGI = 1)then(PC \leftarrow PC + 1)
 SKI
                            pB_*: If (FGO = 1)then(PC \leftarrow PC + 1)
 SKO
                            pB_{\gamma}: IEN \leftarrow 1
 ION
                            pB_a: IEN \leftarrow 0
 IOF
```

### **CONTROL LOGIC GATES**



### **CONTROL OF REGISTERS: (AC)**

 Suppose that we want to derive the gate structure associated with the control inputs of AR. We scan Table 5-6 to find all the statements that change the content of AR:

```
R'T_0: AR \leftarrow PC

R'T_2: .AR \leftarrow IR(0—11)

D'_7IT_3: AR \leftarrow M[AR]

RT_0: AR \leftarrow 0

D_5T_4: AR \leftarrow AR + 1
```

The control functions can be combined into three Boolean expressions as follows:

```
LD (AR) = R'T0 + R'T2 + D'7IT3 / the load input of AR

CLR (AR) = RT0 / the clear input of AR

INR(AR) = D5T4 / the increment input of AR
```

### LD (AR) = R'TO + R'T2 + D'7IT3



INR(AR) = D5T4

CLR(AR) = RT0

